+Tue Dec 5 15:49:31 2000 Owen Taylor <otaylor@redhat.com>
+
+ * INSTALL: Fix link to PNG home, remove reference
+ to fribidi.
+
+ * gdk/x11/gdkevents-x11.c: Fix up for new GMain API.
+
+ * gdk/win32/gdkevents-win32.c: Fix up for new GMain API. (Not
+ tested.)
+
+ * gtk/gtkcheckmenuitem.c: Permanently turn on
+ always_show_toggle.
+
+ * gtk/gtkclist.c (gtk_clist_get_pixtext): Allow mask to
+ be NULL. (Vladimir Klebanov, #26545)
+
+ * gtk/gtkspinbutton.c (gtk_spin_button_insert_text): Fix
+ some signed/unsigned comparison problems. (#6510,
+ David Kaelbling)
+
+ * gtk/gtkwidget.[ch] (gtk_widget_is_ancestor): Change
+ return type to boolean (Oskar Liljeblad, #18648)
+
2000-12-05 Alexander Larsson <alexl@redhat.com>
* gdk/linux-fb/gdkmain-fb.c (gdk_fb_display_new):
+Tue Dec 5 15:49:31 2000 Owen Taylor <otaylor@redhat.com>
+
+ * INSTALL: Fix link to PNG home, remove reference
+ to fribidi.
+
+ * gdk/x11/gdkevents-x11.c: Fix up for new GMain API.
+
+ * gdk/win32/gdkevents-win32.c: Fix up for new GMain API. (Not
+ tested.)
+
+ * gtk/gtkcheckmenuitem.c: Permanently turn on
+ always_show_toggle.
+
+ * gtk/gtkclist.c (gtk_clist_get_pixtext): Allow mask to
+ be NULL. (Vladimir Klebanov, #26545)
+
+ * gtk/gtkspinbutton.c (gtk_spin_button_insert_text): Fix
+ some signed/unsigned comparison problems. (#6510,
+ David Kaelbling)
+
+ * gtk/gtkwidget.[ch] (gtk_widget_is_ancestor): Change
+ return type to boolean (Oskar Liljeblad, #18648)
+
2000-12-05 Alexander Larsson <alexl@redhat.com>
* gdk/linux-fb/gdkmain-fb.c (gdk_fb_display_new):
+Tue Dec 5 15:49:31 2000 Owen Taylor <otaylor@redhat.com>
+
+ * INSTALL: Fix link to PNG home, remove reference
+ to fribidi.
+
+ * gdk/x11/gdkevents-x11.c: Fix up for new GMain API.
+
+ * gdk/win32/gdkevents-win32.c: Fix up for new GMain API. (Not
+ tested.)
+
+ * gtk/gtkcheckmenuitem.c: Permanently turn on
+ always_show_toggle.
+
+ * gtk/gtkclist.c (gtk_clist_get_pixtext): Allow mask to
+ be NULL. (Vladimir Klebanov, #26545)
+
+ * gtk/gtkspinbutton.c (gtk_spin_button_insert_text): Fix
+ some signed/unsigned comparison problems. (#6510,
+ David Kaelbling)
+
+ * gtk/gtkwidget.[ch] (gtk_widget_is_ancestor): Change
+ return type to boolean (Oskar Liljeblad, #18648)
+
2000-12-05 Alexander Larsson <alexl@redhat.com>
* gdk/linux-fb/gdkmain-fb.c (gdk_fb_display_new):
+Tue Dec 5 15:49:31 2000 Owen Taylor <otaylor@redhat.com>
+
+ * INSTALL: Fix link to PNG home, remove reference
+ to fribidi.
+
+ * gdk/x11/gdkevents-x11.c: Fix up for new GMain API.
+
+ * gdk/win32/gdkevents-win32.c: Fix up for new GMain API. (Not
+ tested.)
+
+ * gtk/gtkcheckmenuitem.c: Permanently turn on
+ always_show_toggle.
+
+ * gtk/gtkclist.c (gtk_clist_get_pixtext): Allow mask to
+ be NULL. (Vladimir Klebanov, #26545)
+
+ * gtk/gtkspinbutton.c (gtk_spin_button_insert_text): Fix
+ some signed/unsigned comparison problems. (#6510,
+ David Kaelbling)
+
+ * gtk/gtkwidget.[ch] (gtk_widget_is_ancestor): Change
+ return type to boolean (Oskar Liljeblad, #18648)
+
2000-12-05 Alexander Larsson <alexl@redhat.com>
* gdk/linux-fb/gdkmain-fb.c (gdk_fb_display_new):
+Tue Dec 5 15:49:31 2000 Owen Taylor <otaylor@redhat.com>
+
+ * INSTALL: Fix link to PNG home, remove reference
+ to fribidi.
+
+ * gdk/x11/gdkevents-x11.c: Fix up for new GMain API.
+
+ * gdk/win32/gdkevents-win32.c: Fix up for new GMain API. (Not
+ tested.)
+
+ * gtk/gtkcheckmenuitem.c: Permanently turn on
+ always_show_toggle.
+
+ * gtk/gtkclist.c (gtk_clist_get_pixtext): Allow mask to
+ be NULL. (Vladimir Klebanov, #26545)
+
+ * gtk/gtkspinbutton.c (gtk_spin_button_insert_text): Fix
+ some signed/unsigned comparison problems. (#6510,
+ David Kaelbling)
+
+ * gtk/gtkwidget.[ch] (gtk_widget_is_ancestor): Change
+ return type to boolean (Oskar Liljeblad, #18648)
+
2000-12-05 Alexander Larsson <alexl@redhat.com>
* gdk/linux-fb/gdkmain-fb.c (gdk_fb_display_new):
+Tue Dec 5 15:49:31 2000 Owen Taylor <otaylor@redhat.com>
+
+ * INSTALL: Fix link to PNG home, remove reference
+ to fribidi.
+
+ * gdk/x11/gdkevents-x11.c: Fix up for new GMain API.
+
+ * gdk/win32/gdkevents-win32.c: Fix up for new GMain API. (Not
+ tested.)
+
+ * gtk/gtkcheckmenuitem.c: Permanently turn on
+ always_show_toggle.
+
+ * gtk/gtkclist.c (gtk_clist_get_pixtext): Allow mask to
+ be NULL. (Vladimir Klebanov, #26545)
+
+ * gtk/gtkspinbutton.c (gtk_spin_button_insert_text): Fix
+ some signed/unsigned comparison problems. (#6510,
+ David Kaelbling)
+
+ * gtk/gtkwidget.[ch] (gtk_widget_is_ancestor): Change
+ return type to boolean (Oskar Liljeblad, #18648)
+
2000-12-05 Alexander Larsson <alexl@redhat.com>
* gdk/linux-fb/gdkmain-fb.c (gdk_fb_display_new):
+Tue Dec 5 15:49:31 2000 Owen Taylor <otaylor@redhat.com>
+
+ * INSTALL: Fix link to PNG home, remove reference
+ to fribidi.
+
+ * gdk/x11/gdkevents-x11.c: Fix up for new GMain API.
+
+ * gdk/win32/gdkevents-win32.c: Fix up for new GMain API. (Not
+ tested.)
+
+ * gtk/gtkcheckmenuitem.c: Permanently turn on
+ always_show_toggle.
+
+ * gtk/gtkclist.c (gtk_clist_get_pixtext): Allow mask to
+ be NULL. (Vladimir Klebanov, #26545)
+
+ * gtk/gtkspinbutton.c (gtk_spin_button_insert_text): Fix
+ some signed/unsigned comparison problems. (#6510,
+ David Kaelbling)
+
+ * gtk/gtkwidget.[ch] (gtk_widget_is_ancestor): Change
+ return type to boolean (Oskar Liljeblad, #18648)
+
2000-12-05 Alexander Larsson <alexl@redhat.com>
* gdk/linux-fb/gdkmain-fb.c (gdk_fb_display_new):
http://www.pango.org/download.shtml
- Pango also requires the FriBidi library, available from:
-
- http://imagic.weizmann.ac.il/~dov/freesw/FriBidi/
-
- The TIFF, PNG, and JPEG image loading libraries. You most
likely have these installed on your system already. If not
these libraries are available from:
http://www.libtiff.org/
- ftp://swrinde.nde.swri.edu/pub/png/src/
+ http://www.libpng.org/
ftp://ftp.uu.net/graphics/jpeg/
If these libraries are not available, the corresponding
MSG *msg,
gboolean *ret_val_flagp,
gint *ret_valp);
-static gboolean gdk_event_prepare (gpointer source_data,
- GTimeVal *current_time,
- gint *timeout,
- gpointer user_data);
-static gboolean gdk_event_check (gpointer source_data,
- GTimeVal *current_time,
- gpointer user_data);
-static gboolean gdk_event_dispatch (gpointer source_data,
- GTimeVal *current_time,
- gpointer user_data);
+
+static gboolean gdk_event_prepare (GSource *source,
+ gint *timeout);
+static gboolean gdk_event_check (GSource *source);
+static gboolean gdk_event_dispatch (GSource *source,
+ GSourceFunc callback,
+ gpointer user_data);
/* Private variable declarations
*/
void
gdk_events_init (void)
{
+ GSource *source;
HRESULT hres;
#ifdef USE_TRACKMOUSEEVENT
HMODULE user32, imm32;
msh_mousewheel_msg = RegisterWindowMessage ("MSWHEEL_ROLLMSG");
GDK_NOTE (EVENTS, g_print ("MSH_MOUSEWHEEL = %#x\n", msh_mousewheel_msg));
- g_source_add (GDK_PRIORITY_EVENTS, TRUE, &event_funcs, NULL, NULL, NULL);
+ source = g_source_new (&event_funcs, sizeof (GSource));
+ g_source_set_priority (source, GDK_PRIORITY_EVENTS);
event_poll_fd.fd = G_WIN32_MSG_HANDLE;
event_poll_fd.events = G_IO_IN;
- g_main_add_poll (&event_poll_fd, GDK_PRIORITY_EVENTS);
+ g_source_add_poll (source, &event_poll_fd);
+ g_source_set_can_recurse (source, TRUE);
+ g_source_attach (source, NULL);
+
+ g_source_add (GDK_PRIORITY_EVENTS, TRUE, &event_funcs, NULL, NULL, NULL);
hres = CoCreateInstance (&CLSID_CActiveIMM,
NULL,
}
}
-static gboolean
-gdk_event_prepare (gpointer source_data,
- GTimeVal *current_time,
- gint *timeout,
- gpointer user_data)
+static gboolean
+gdk_event_prepare (GSource *source,
+ gint *timeout)
{
MSG msg;
gboolean retval;
return retval;
}
-static gboolean
-gdk_event_check (gpointer source_data,
- GTimeVal *current_time,
- gpointer user_data)
+static gboolean
+gdk_event_check (GSource *source)
{
MSG msg;
gboolean retval;
return retval;
}
-static gboolean
-gdk_event_dispatch (gpointer source_data,
- GTimeVal *current_time,
- gpointer user_data)
+static gboolean
+gdk_event_dispatch (GSource *source,
+ GSourceFunc callback,
+ gpointer user_data)
{
GdkEvent *event;
XPointer arg);
#endif
-static gboolean gdk_event_prepare (gpointer source_data,
- GTimeVal *current_time,
- gint *timeout,
- gpointer user_data);
-static gboolean gdk_event_check (gpointer source_data,
- GTimeVal *current_time,
- gpointer user_data);
-static gboolean gdk_event_dispatch (gpointer source_data,
- GTimeVal *current_time,
- gpointer user_data);
+static gboolean gdk_event_prepare (GSource *source,
+ gint *timeout);
+static gboolean gdk_event_check (GSource *source);
+static gboolean gdk_event_dispatch (GSource *source,
+ GSourceFunc callback,
+ gpointer user_data);
GdkFilterReturn gdk_wm_protocols_filter (GdkXEvent *xev,
GdkEvent *event,
gdk_event_prepare,
gdk_event_check,
gdk_event_dispatch,
- (GDestroyNotify)g_free
+ NULL
};
GPollFD event_poll_fd;
void
gdk_events_init (void)
{
+ GSource *source;
+
connection_number = ConnectionNumber (gdk_display);
GDK_NOTE (MISC,
g_message ("connection number: %d", connection_number));
- g_source_add (GDK_PRIORITY_EVENTS, TRUE, &event_funcs, NULL, NULL, NULL);
+ source = g_source_new (&event_funcs, sizeof (GSource));
+ g_source_set_priority (source, GDK_PRIORITY_EVENTS);
+
event_poll_fd.fd = connection_number;
event_poll_fd.events = G_IO_IN;
- g_main_add_poll (&event_poll_fd, GDK_PRIORITY_EVENTS);
+ g_source_add_poll (source, &event_poll_fd);
+ g_source_set_can_recurse (source, TRUE);
+ g_source_attach (source, NULL);
gdk_add_client_message_filter (gdk_wm_protocols,
gdk_wm_protocols_filter, NULL);
w = GDK_WINDOW_XWINDOW (gdk_xim_window);
break;
}
-
+
if (XFilterEvent (&xevent, w))
continue;
#else
}
static gboolean
-gdk_event_prepare (gpointer source_data,
- GTimeVal *current_time,
- gint *timeout,
- gpointer user_data)
+gdk_event_prepare (GSource *source,
+ gint *timeout)
{
gboolean retval;
}
static gboolean
-gdk_event_check (gpointer source_data,
- GTimeVal *current_time,
- gpointer user_data)
+gdk_event_check (GSource *source)
{
gboolean retval;
}
static gboolean
-gdk_event_dispatch (gpointer source_data,
- GTimeVal *current_time,
- gpointer user_data)
+gdk_event_dispatch (GSource *source,
+ GSourceFunc callback,
+ gpointer user_data)
{
GdkEvent *event;
{
g_return_if_fail (menu_item != NULL);
g_return_if_fail (GTK_IS_CHECK_MENU_ITEM (menu_item));
-
+
+#if 0
menu_item->always_show_toggle = always != FALSE;
+#endif
}
void
gtk_check_menu_item_init (GtkCheckMenuItem *check_menu_item)
{
check_menu_item->active = FALSE;
- check_menu_item->always_show_toggle = FALSE;
+ check_menu_item->always_show_toggle = TRUE;
}
static gint
*pixmap = GTK_CELL_PIXTEXT (clist_row->cell[column])->pixmap;
/* mask can be NULL */
- *mask = GTK_CELL_PIXTEXT (clist_row->cell[column])->mask;
+ if (mask)
+ *mask = GTK_CELL_PIXTEXT (clist_row->cell[column])->mask;
return 1;
}
gint i;
GdkWChar pos_sign;
GdkWChar neg_sign;
- guint entry_length;
+ gint entry_length;
entry_length = entry->text_length;
}
if (dotpos > -1 && *position > dotpos &&
- spin->digits - entry_length
+ (gint)spin->digits - entry_length
+ dotpos - new_text_length + 1 < 0)
return;
{
if (!spin->digits || dotpos > -1 ||
(new_text_length - 1 - i + entry_length
- - *position > spin->digits))
+ - *position > (gint)spin->digits))
return;
dotpos = *position + i;
}
* results:
*****************************************/
-gint
+gboolean
gtk_widget_is_ancestor (GtkWidget *widget,
GtkWidget *ancestor)
{
gint *x,
gint *y);
-gint gtk_widget_is_ancestor (GtkWidget *widget,
+gboolean gtk_widget_is_ancestor (GtkWidget *widget,
GtkWidget *ancestor);
/* Hide widget and return TRUE.